草庐IT

javascript - 实例上的正则表达式总匹配

全部标签

Ruby 正则表达式提取单词

我目前正在努力想出一个可以将字符串拆分为单词的正则表达式,其中单词被定义为由空格包围或包含在双引号之间的字符序列。我正在使用String#scan例如,字符串:'hello"myname"is"Tom"'应该匹配单词:hellomynameisTom我使用以下方法成功匹配了双引号中的单词:/"([^\"]*)"/但我无法弄清楚如何合并被空白字符包围的“你好”、"is"和“汤姆”,同时又不会搞砸“我的名字”。如有任何帮助,我们将不胜感激! 最佳答案 result='hello"myname"is"Tom"'.split(/\s+(?=

ruby-on-rails - Ruby:我可以在类方法中使用实例方法吗?

我有一个包含此类方法的类:defself.get_event_record(row,participant)event=Event.where(:participant_id=>participant.id,:event_type_code=>row[:event_type],:event_start_date=>self.format_date(row[:event_start_date])).firstevent=Event.new(:participant_id=>participant.id,:event_type_code=>row[:event_type],:event_s

ruby - 如何在 Ruby 中使正则表达式的一部分成为可选的?

要匹配以下内容:OnMar3,201111:05AM,"mrperson"wrote:我有以下正则表达式:/(On.*(?:Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\d{1,2},[12]\d{3}.*at\d{1,2}:\d{1,2}(?:AM|PM),.*wrote:)/m有没有办法让at成为可选的?所以如果它在那里很好,如果没有,它仍然匹配吗? 最佳答案 当然。把它放在括号里,在它后面打一个问号。包括其中一个空格(否则,如果缺少“at”,您将尝试匹配两个空格。)(at)?

ruby - 将实例方法委托(delegate)给类方法

在Ruby中,假设我有一个类Foo允许我对我的大量Foos进行分类。所有Foos都是绿色和球形的是自然界的基本法则,因此我定义了类方法如下:classFoodefself.colour"green"enddefself.is_spherical?trueendend这让我做Foo.colour#"green"但不是my_foo=Foo.newmy_foo.colour#Error!尽管my_foo显然是绿色的。显然,我可以定义一个调用self.class.colour的实例方法colour,但如果我有很多这样的基本特征,那将变得笨拙。我大概也可以通过定义method_missing来尝

ruby-on-rails - 最佳实践 - 在 Ruby on Rails View 中传递实例变量或使用参数?

根据下面的例子,最佳实践是什么?案例一controller.rb...defindex...@group=params[:group]@team=params[:team]@org=params[:org]...endindex.html.haml=link_to@group,'#'=link_to@team,'#'=link_to@org,'#'案例2controller.rb...defindex......endindex.html.haml=link_toparams[:group],'#'=link_toparams[:team],'#'=link_toparams[:org

ruby - 正则表达式 : Any characters except sequence

[^abc]Anysinglecharacterexcept:a,b,orc但是我如何为除序列abc之外的任何字符制作正则表达式所以,类似的东西"Helloabcawesomeworld".scan/[^(abc)]+/将返回“Hello”和“awesomeworld”。PS:而且不是分割字符串 最佳答案 这叫做lookaround,在您的情况下,您需要使用负前瞻。我不确定Ruby中的确切语法,但(?!abc)中的某些内容可能会起作用。请注意,lookaround不会消耗任何输入,因此您需要在其后跟任何您想要匹配的模式。也许(?:(

ruby - 在一行中查找不区分大小写的单词匹配项

我需要查找一行中出现的所有单词,但搜索必须不区分大小写。我还需要向我的正则表达式添加什么?arr=line.scan(/\s+#{word}\s+/) 最佳答案 你需要修饰符/iarr=line.scan(/\b#{word}\b/i)http://www.tutorialspoint.com/ruby/ruby_regular_expressions.htm最好使用\b作为单词边界,因为正则表达式中的第二个\s+eats空格,可用于另一个匹配词的第一个\s+;您的正则表达式在行首和行尾也失败:>"asdasdasdasd".sca

ruby - 正则表达式的 o 修饰符是什么意思?

Ruby正则表达式有一些选项(例如i、x、m、o)。例如,i表示忽略大小写。o选项是什么意思?在riRegexp中,它说o表示只执行一次#{}插值。但是当我这样做时:a='one'b=/#{a}/a='two'b不变(它保持为/one/)。我错过了什么? 最佳答案 直接来自thego-tosourceforregularexpressions:/ocausesany#{...}substitutionsinaparticularregexliteraltobeperformedjustonce,thefirsttimeitiseva

ruby - 在 Ruby 的情况下使用带正则表达式匹配的命名捕获……什么时候?

我想使用命名捕获来解析用户输入以提高可读性。当他们键入命令时,我想捕获一些参数并传递它们。我在case语句中使用RegExp,因此无法分配/pattern/.named_captures的返回值。这是我希望能够做的(例如):whilecommand!="quit"print"Command:"command=gets.chompcasecommandwhen/load(?\w+)/load(filename)endend 最佳答案 namedcaptures在此语法时设置局部变量。regex-literal=~string不要在其他

ruby - 用于类似正则表达式匹配的 xpath 表达式?

我想在具有特定模式的html文档中搜索divid。我想在正则表达式中匹配这个模式:foo_([[:digit:]]{1.8})使用xpath。上述模式的xpath等价物是什么?我坚持//div[@id="foo_然后什么?如果有人能为它继续一个合法的表达。编辑抱歉,我想我必须详细说明一下。其实不是foo_,它是post_message_顺便说一句,我使用mechanize/nokogiri(ruby​​)这是片段:html_doc=Nokogiri::HTML(open(myfile))message_div=html_doc.xpath('//div[substring(@id,13